<template>
  <el-card>
    <el-row :gutter="20" class="header">
      <el-col :span="4">
        <el-input
          :placeholder="$t('table.placeholder')"
          clearable
          v-model="queryFrom.query"
        ></el-input>
      </el-col>
      <el-button type="primary" :icon="Search" @click="initGetUsersList">{{
        $t('table.search')
      }}</el-button>
      <!-- @click="handleDialogValue" 与 @click="handleDialogValue()" ;  如果不加括号，函数的第一个参数为event   如果加了括号，需要手动传入$event才能获得事件对象。-->
      <!-- 这里要传入一个空,而不是$event 所以handleDialogValue 事件 需要添加() -->
      <el-button type="primary" @click="handleDialogValue()">{{
        $t('table.adduser')
      }}</el-button>
    </el-row>
    <!-- prop 是对应 tableData  中的字段名；   字段名称 对应列内容的字段名，-->
    <el-table :data="tableData" stripe style="width: 100%">
      <el-table-column
        :width="item.width"
        :prop="item.prop"
        :label="$t(`table.${item.label}`)"
        v-for="(item, index) in options"
        :key="index"
      >
        <!-- #default="scope" 作用域插槽； v-slot="{ row }" 的row就是从scope 解构出来的  -->
        <!-- element 中tables 表格，自定义列需要使用 slot  -->
        <!-- 因为这里 不仅仅用到了后台接口的数据，还用到了 el-switch 标签，所以需要自定义列 -->
        <!-- change switch 状态发生变化时的回调函数 -->
        <template v-slot="{ row }" v-if="item.prop === 'mg_state'">
          <el-switch
            v-model="row.mg_state"
            @change="changeState(row)"
          ></el-switch>
        </template>
        <!-- 需要对时间进行加工处理， 所以需要自定义列 -->
        <template v-slot="{ row }" v-else-if="item.prop === 'create_time'">
          {{ $filters.filterTimes(row.create_time) }}
        </template>
        <!-- 默认插槽 v-slot:的语法糖是#，但后面必须有插槽名，例如v-slot:default 等价于 #default  -->
        <!-- 自定义列需要使用 slot -->
        <!--  这里用到了el-button， 所以需要自定义列-->
        <!-- 注意，这里的row，不是取展示页面上一行的信息，而是取后台api返回的一行的信息；
        所以这里row 可以取到虽然页面上没展示，但是后台api返回的字段的信息 -->
        <template #default="{ row }" v-else-if="item.prop === 'action'">
          <el-button type="primary" size="small" :icon="Edit" @click="handleDialogValue(row)"></el-button>
          <el-button type="warning" size="small" :icon="Setting"></el-button>
          <el-button type="danger"  size="small" :icon="Delete" @click="delUser(row)" ></el-button>
        </template>
      </el-table-column>
    </el-table>
    <!--  分页-->
    <!-- size-change 新每页条数   pageSize 改变时触发  -->
    <!-- current-change 新当前页    current-change 改变时触发-->
    <el-pagination
        v-model:currentPage="queryFrom.pagenum"
        v-model:page-size="queryFrom.pagesize"
        :page-sizes="[2, 5, 10, 15]"
        :small="small"
        :disabled="disabled"
        :background="background"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total"
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
      >
      </el-pagination>
  </el-card>
  <!-- model-value / v-model 是否显示 Dialog,element 自带的写法 -->
  <!-- v-if 解决重新点击添加用户的时候，form表单里数据要是空的 -->
  <!-- initUserList 是子组件 添加用户 确认按钮，传过来的事件，解决用户添加信息后页面不渲染刚添加的用户信息-->
  <Dialog
    v-model="dialogVisible"
    :dialogTitle="dialogTitle"
    v-if="dialogVisible"
    @initUserList="initGetUsersList"
    :dialogTableValue="dialogTableValue"
  ></Dialog>
  <div>users</div>
</template>

<script setup>
import { Search, Edit, Setting, Delete } from '@element-plus/icons-vue'
import { ref } from 'vue'
import { getUser, changeUserState, deleteUser } from '@/api/users.js'
import { options } from './options'
import { ElMessage, ElMessageBox } from 'element-plus'
import { useI18n } from 'vue-i18n'
import Dialog from './components/dailog.vue'
import { isNull } from '@/utils/filters'
const i18n = useI18n()
const dialogTableValue = ref({})

const queryFrom = ref({
    query: '', // 后端定义的参数名，查询参数
    pagenum: 1, // 后端定义的参数名，当前页码
    pagesize: 10 // 后端定义的参数名，每页显示条数
})
const tableData = ref([])
const total = ref(0)
const dialogVisible = ref(false)
const dialogTitle = ref('')

const initGetUsersList = async () => {
  const result = await getUser(queryFrom.value)
  total.value = result.total
  tableData.value = result.users
  console.log(result.users)
}
initGetUsersList()

const handleSizeChange = (pagesize) => {
  // 更改 新每页条数，都从第一页 开始展示
  queryFrom.value.pagenum = 1
  queryFrom.value.pagesize = pagesize
  initGetUsersList()
}

// Go to 跳转到 哪一页
const handleCurrentChange = (pagenum) => {
  queryFrom.value.pagenum = pagenum
  initGetUsersList()
}

const changeState = async (info) => {
  // 调用 后台接口，更改数据库中 mg_state 的值
  await changeUserState(info.id, info.mg_state)
  // 更新完成后的消息提示
  ElMessage({
    message: i18n.t('message.updateSuccess'),
    type: 'success'
  })
}

const handleDialogValue = (row) => {
    if (isNull(row)) {
        dialogTitle.value = '添加用户'
        // 用 dialogTableValue 来区分 是添加用户 还是 编辑用户
        dialogTableValue.value = {}
      } else {
        dialogTitle.value = '编辑用户'
        console.log(row)
        // JSON.parse() 把JSON字符串 转换为 JavaScript值或对象
        // JSON.stringify  把 JavaScript 对象或值转换为 JSON 字符串
        dialogTableValue.value = JSON.parse(JSON.stringify(row))
  }
        dialogVisible.value = true // 显示dialog 对话框
}

// 删除用户
const delUser = (row) => {
  ElMessageBox.confirm(i18n.t('dialog.deleteTitle'), 'Warning', {
    confirmButtonText: '确认',
    cancelButtonText: '取消',
    type: 'warning'
  })
     // 点击确认执行下面的代码
    .then(async () => {
      await deleteUser(row.id)
      ElMessage({
        type: 'success',
        message: 'Delete completed'
      })
      initGetUsersList()
    })
     //  点击 取消 按钮 执行下面的代码
    .catch(() => {
      ElMessage({
        type: 'info',
        message: 'Delete canceled'
      })
    })
}
</script>

<style lang="scss" scoped>
.header {
  padding-bottom: 16px;
  box-sizing: border-box;
}

::v-deep .el-input__suffix {
  align-items: center;
}
/* 分页放到 右边 */
::v-deep .el-pagination {
  padding-top: 16px;
  box-sizing: border-box;
  text-align: right;
}
</style>
